* {
    box-sizing: border-box;
}

body {
    margin: 0;
    padding: 0;
    /* background-color: var(--clr-background); */
    background: linear-gradient(135deg, #3c3c3c, #6a11cb, #1ca78b);
    font-family: 'Trebuchet MS', 'Lucida Sans Unicode', 'Lucida Grande', 'Lucida Sans', Arial, sans-serif;
    transition: 0.3s linear;
    display: inline-block;
    align-items: center;
    justify-content: center;
    width: 100vw;
    height: 100%;
    min-height: 100vh;
    background-size: 300% 300%;
    max-width: 99vw;
   animation: gradient 12s cubic-bezier(1,0,0,1) infinite;
}



:root{
    --clr-text: #1ca78b;
    --clr-textitems: #3c3d3c;
    --clr-navbar: #1ca78b;
    --clr-background: #e8e8e8; 
    --clr-items: #c0c7cc;
    --clr-textgrey: #3c3d3c;
}

.dark-mode{
    --clr-text: #1ca78b;
    --clr-background: #5c5e5c; 
    --clr-items: #3c3d3c;
    --clr-textgrey: #3c3d3c;
    --clr-textitems: #1ca78b;
}

#container-new{
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-bottom: 5vh;
}

h2, p{
    /* color: black;
    text-decoration: underline #1ca78b; */
    color: #e8e8e8;
}


.hero-h2{
    font-size: 5em;
}

span.red-dot{
    display: inline-block;
    color: #f2182a;
    background-color: #f2182a;
    border: 2px #f2182a;
    border-radius: 360px;
    width: 1rem;
    height: 1rem;
}

.input-container{
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.hide{
    display: none;
}













/*nav bar stuff */


.header-si{
    display: flex;
    justify-content: left;
    margin-right: 75%;
}


.header-bg{
    position: relative;
    margin: 0;
    padding: 0;
    height: 5em;
    background-color: #fff;
    text-decoration: none;
}


/* .main-logo{
    max-width: 40%;
    margin-left: 3rem;
    margin-top: -12%;
} */

#nav-a{
    padding: 0;
    color: #1ca78b;
    text-decoration: none;
}

.right-cont{
    justify-content: right;
}

.icon-container-nav{
    display: flex;
    flex-direction: row;
    margin-left: -15em;
    margin-top: 1.5em;
    padding: 1%;
}



.notify-bell{
    color: #1ca78b;
}

.notis{
    padding-left: 1.5em;
}



.account-icon-phone{
    display: none !important;
}




.main-logo{
    max-width: 40%;
    margin-left: 3rem;
    margin-top: -12%;
}






ul{
    list-style:none;
    text-align: right;
}

li{
    margin-bottom: 2%;
}

li a{
  color: #1ca78b;  
  padding: 0;
  text-decoration: none;
  list-style: none;
}

li a:hover{
    color: #1ca78b;  
    text-decoration: underline 1px #1ca78b;
  }

.dropdown-1{
    position: absolute;
    padding: 1%;
    max-width: 15em;
    min-width: 10em;
    background-color: #fff;
    color: #1ca78b;
    list-style: none;
    text-decoration: none;
    opacity: 100;
    right: 4%;
    top: 5em;
}





.search-container{
    z-index: 0;
    text-align: center;
    margin: 0 auto  ;
    margin-top: 1.5em;
    margin-left: 10%;
}

p.dismiss{
    text-decoration: underline;
    color: blue;
    cursor: grabbing;
}

button.search{
    min-width: 5em;
    max-width: 5em;
    min-height: 2em;
    max-height: 2em;
    background-color: #1ca78b;
    border: none;
    border-radius: 27px 0px 0px 27px;
}

.search-container{
    min-height: 5vh;
    max-height: 5vh;
}

button.search:hover{
    transform: none;
    background-color: #1ca78b;
}

input.search-bar{
    width: 5em;
    border-radius: 0px 27px 27px 0px;
}


.search-form{
    text-align: center;
    display: flex;
    flex-direction: row;
    width: 500px;
}

.search-bar{
    height: 2em;
    width: 50px;
    border-radius: 0px 0px 0px 27px;
}

div.sign-in a{
    display: flex;
    flex-direction: row;
    color: #1ca78b;
}

.sign-in p:hover{
    color: #1ca78b;
    text-decoration: underline 2px #1ca78b;
}

.sign-in p{
    color: #1ca78b;
    text-decoration: none;
    padding: 0;
}


.sign-in span{
    margin-left: .25em;
}

.sign-in span:hover{
    text-decoration: none;
}



.notis-num{
    color: #3c3d3c;
    font-weight: 600;
    background-color: #f2182a;
    border-radius: 27px;
    height: 1.5em;
    padding-left: .5rem;
    padding-right: .5rem;
    
}


.phone-notis{
    display: none;
}





















/* cokkie pop up */

.cookie-pop-up{
    text-align: center;
    margin-left: 34%;
    top: 20px;
    bottom: 1%;
    z-index: 100;
    position: sticky;
    height: fit-content;
    width: fit-content;
    padding: 1%;
    margin-bottom: 1%;
    background-color: #3c3d3c;
    color: #1ca78b;
}



.cookie-pop-up p{
    margin-bottom: 0;
}

.cookie-pop-up p a{
    margin-bottom: 0;
    color: #1ca78b;
}

.cookie-pop-up p a:hover{
    margin-bottom: 0;
    color: #1ca78b;
    text-decoration: underline #1ca78b 2px;
}


.cookie-buttons{
    display: flex;
    flex-direction: row;
    text-align: center;
}

.cookie-btn{
    text-align: center;
    margin-bottom: 2%;
    border-radius: 27px;
    width: 10vw;
}

.reject{
    margin-left: 2vw;
}

.accept{
    margin-left: 1vw;
}













/* search bar */








/* features */

.options{
    margin-top: 0%;
}

.options-genre{
display: none;
}

div.options{
text-align: center;
align-items: center;
}

button.features{
    margin-top: 1.5rem;
    margin-bottom: 0.5%;
    width: 125px;
    background-color: #1ca78b;
    border: solid 3px #1ca78b;
}


button.features-long{
    margin-top: 0;
    margin-bottom: 0.5%;
    width: 200px;
    background-color: #1ca78b;
    border: solid 3px #1ca78b;
}

button.round{
    box-shadow: 2px 1px 3px 1px #3c3d3c; 
    border-radius: 27px;
}




.sorting-con{
    display: flex;
    flex-direction: row;
    max-width: 70%;
    margin-left: 15.5%;
    padding: .5rem;
    align-items: center;
    justify-content: center;
    text-align: center;
}


#genreSelect{
    margin-left: 1.5rem;
}

.btn-con{
    display: flex;
    padding: .5rem;
    align-items: center;
    justify-content: center;
    text-align: center;
}


label.sort-label{
    padding: .25rem;
    color: black;
    font-weight: 600;
}

option.general-sort{
    max-width: fit-content;
    padding: 1.5rem;
}


select{
    background-color: #1ca78b;
    border-radius: 27px;
    border: 2px #1ca78b solid;
    color: black;
    width: 7.5rem;
    font-weight: 600;
}


.top-con{
    background: linear-gradient(135deg, #3c3c3c, #6a11cb, #1ca78b);
    animation: gradient 12s ease-in-out infinite;
}



.hero {
    background: linear-gradient(35deg, #fff, #1ca78b, #979797);
    color: #fff;
    text-align: center;
    padding: 4rem 2rem;
    background-size: 200% 200%;
   /* animation: gradient 8s ease-in-out infinite; */
  }
  











@keyframes gradient{
    0%{
        background-position: 0 50%;
    }
    50%{
        background-position: 100% 85%;
    }

    100%{
        background-position: 0 75%;
    }
}



.call-to-action{
    
    box-shadow: 2px 3px 3px 1px #3c3c3c;
}


.cta-con {
    display: flex;
    justify-content: center; 
    align-items: center; 
    text-align: center;
    padding-bottom: 2.5em;
  }






























































/* general page */

button{
    margin-top: 30%;
    width: 15vw;
    background-color: #1ca78b;
    border: solid 3px #1ca78b;
    /* box-shadow: 2px 3px 3px 1px #3c3d3c; */
}

button.buy-btn{
    width: 5em;
    padding: 0.5%;
    background-color: #f2182a;
    border: solid 3px #f2182a;
    border-radius: 27px;
    /* box-shadow: 2px 3px 3px 1px #3c3d3c; */
}



button:hover{
    transform: scale(1.1);
    transition: 0.3s ease-in-out;
    background-color: #fff;
    border-width: 1px;
    color: #1ca78b;
}


button.search:hover{
    transition: 0.3s ease-in-out;
    background-color: #1ca78b;
    border-width: 1px;
    color: #3c3d3c;
}




.container {
            max-width: 1200px;
            margin: 0 auto;
            padding: 0 24px;
        }

        /* Placeholder Header/Footer (Remove when adding yours) */
        .placeholder-header,
        .placeholder-footer {
            background: var(--charcoal);
            border: 2px dashed var(--teal);
            padding: 40px;
            text-align: center;
            color: var(--text-muted);
            font-family: var(--font-display);
        }

        .placeholder-header {
            margin-bottom: 60px;
        }

        .placeholder-footer {
            margin-top: 60px;
        }

    
        .intro-section {
            padding: 100px 24px;
        }

        .intro-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 80px;
            align-items: center;
        }

        .intro-text h1 {
            font-family: var(--font-display);
            font-size: 48px;
            font-weight: 800;
            line-height: 1.2;
            margin-bottom: 24px;
            background: linear-gradient(135deg, var(--teal) 0%, var(--purple) 100%);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }

        .intro-text p {
            font-size: 18px;
            line-height: 1.8;
            color: var(--text-muted);
            margin-bottom: 20px;
        }

        .intro-image {
            position: relative;
            border-radius: 24px;
            overflow: hidden;
            box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
        }

        .intro-image img {
            width: 100%;
            height: 500px;
            object-fit: cover;
            display: block;
            transition: transform 0.5s ease;
        }

        .intro-image:hover img {
            transform: scale(1.05);
        }

        .image-badge {
            position: absolute;
            bottom: 24px;
            left: 24px;
            background: linear-gradient(135deg, #3c3c3c, #6a11cb, #1ca78b);
            color: #fff;
            padding: 12px 24px;
            border-radius: 100px;
            font-size: 14px;
            font-weight: 700;
            box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
        }


        div.section-2, .section-4{
            align-items: center;
            text-align: center;
        }

        .section-2-desc{
            padding-left: 7em;
            padding-right: 7em;
            padding-top: 2em;
            font-size: 1.2em;
        }


        .amplify{
            font-size: 1.5em;
        }

        .section-2 h2{
            font-size: 3em;
        }
        .section-4 h2{
            margin-top: 2rem;
            font-size: 3em;
        }
 
        .benefits-section {
            padding: 100px 24px;
            background: var(--bg-darker);
        }

        .section-title {
            font-family: var(--font-display);
            font-size: 42px;
            font-weight: 800;
            text-align: center;
            margin-bottom: 60px;
        }

        .benefits-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 40px;
        }

        .benefit-block {
            background: var(--charcoal);
            border: 2px solid var(--border);
            border-radius: 24px;
            padding: 40px;
            text-align: center;
            transition: all 0.4s ease;
        }

        .benefit-block:hover {
            border-color: var(--teal);
            transform: translateY(-8px);
            box-shadow: 0 20px 40px rgba(28, 167, 139, 0.2);
        }

        .benefit-icon {
            font-size: 64px;
            margin-bottom: 24px;
        }

        .benefit-block h3 {
            font-family: var(--font-display);
            font-size: 24px;
            font-weight: 700;
            margin-bottom: 16px;
            color: var(--teal);
        }

        .benefit-block p {
            font-size: 16px;
            line-height: 1.7;
            color: var(--text-muted);
        }


        .email-con{
            padding: 2rem;
            color: #fff;
            display: flex;
            align-items: center !important;
            text-align: center !important;
            justify-content: center !important;
        }


        .email-form{
            background-color: #e8e8e8;
            width: 50vw;
            padding: 2rem;
        }

        label{
            color: #1ca78b;
        }


        .submit{
            max-width: 150px;
            margin-top: 2rem;
        }

        .email-h3{
            color: #1ca78b;
            padding-bottom: 2rem;
        }


        .compliance{
            color: #1ca78b;
            padding-bottom: 1rem;
            margin-top: 2rem;
        }

.post-info-bottom-row{
    display: flex;
    flex-direction: column !important;
}

.type{
    margin-left: 1rem;
}

button.cookie-btn:hover{
    transform: scale(1.1);
    transition: 0.3s ease-in-out;
    background-color: #1ca78b;
    border-width: 1px;
    color: #3c3d3c;
}


button.buy-btn:hover{
    transform: scale(1) !important;
    transition: 0.3s ease-in-out;
    background-color: #f2182a;
    border: solid 2px #3c3d3c;
    color: #3c3d3c;
}

.buy-btn{
    background-color: #f2182a;
    border: 2px solid #f2182a;
    width: 10em !important;
    border-radius: 27px !important;
    margin-bottom: 3rem;
}


.section-3{
    display: flex;
       text-align: center !important;
    align-items: center !important;
    justify-content: center;
}


.section-3-desc{
    color: #3c3c3c;
    margin-top: 1rem;
}


.section-3-h3{
    border-bottom: 2px #1ca78b solid;
    padding-bottom: .5rem;
    font-weight: 750;
}


.benefits{
    display: flex;
    flex-direction: row;
    text-align: center !important;
    align-items: center !important;
}

.benefit-card{
    background-color: #fff;
    border: 4px solid #1ca78b;
    border-radius: 15px;
    padding: 3rem;
    margin: 3rem;
    width: 25rem;
    height: 30rem;
    box-shadow: 10px 10px 10px 10px rgba(35, 36, 36, 0.2);
    transition: 0.4s ease-in-out;
}

.benefit-card:hover{
    transform: scale(1.05) translateY(-2px);
}


.checkout-btn{
    margin-left: 2rem;
    width: 5em !important;
    transform: scale(0.8);
}

span.dollar{
    background-color: #1ca78b;
}



.content{
    background-color: #3c3c3c;
    border: 3px solid #1ca78b;
    border-radius: 27px;
    margin-bottom: .75rem;
}




.info{
    font-weight: bold;
    color: #e8e8e8 !important;
}


.info-row{
    display: flex;
    flex-direction: row !important;
    margin-bottom: 0;
}


.thumb{
    padding-top: 0;
    padding-bottom: 0;
    margin-top: .75rem;
    width: 17vw;
    max-width: 17vw;
    max-height: 30vh;
    border-radius: 27px;
    inline-size: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}










.blurred-image {
    filter: blur(20px);
    transition: filter 0.5s ease;
}




.blurring{
    filter: blur(10px);
    transition: filter 0.5s ease;
}


span{
    height: 4vh;
}

select{
    height: 2rem;
}

.option{
    margin-left: 1vw;
}

.h2.message{
    color: #1ca78b;
}

p.type{
    text-align: center;
    border: 2px 2px 2px 2px #3c3d3c;
    border-radius: 10%;
    padding: 0.5%;
    background-color: #0aa183;
    color: #3c3c3c !important;
    width: 5em;
    border-radius: 27px;
}

.price-text{
    font-size: x-large;
    font-weight: 600;   
    padding-right: .5rem;
    color: #e8e8e8;
}

.price-row{
    display: flex;
    flex-direction: row !important;
    margin-bottom: 0;
}


.card-body{
    margin-bottom: -1.5rem;
}

.alert{
    color: #000 !important;
}

.card-title, h2{
    color: #e8e8e8;
    margin-top: 2rem;
}

.card-text{
    color: #e8e8e8;
}


.invalid{
    color: #d9534f;
}

/* a{
    color: #3c3d3c;
    text-decoration: none;
} */



.card-body a:hover{
    color: #3c3c3c !important;  
    text-decoration: underline 1px #1ca78b !important;
}

.subscription-display{
    background-color: #1ca78b;
    color: #3c3c3c;
    border-radius: 10px;
    border: 3px solid black;
}


.pricing-heading{
    color: #e8e8e8;
}










/* Email Form Message Styles */

.form-message {
    margin: 1rem 0;
    padding: 1rem;
    border-radius: 4px;
    font-size: 1rem;
    line-height: 1.5;
    transition: all 0.3s ease;
}

.form-message.success {
    background-color: #d4edda;
    color: #155724;
    border: 1px solid #c3e6cb;
}

.form-message.error {
    background-color: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
}

.form-message:empty {
    display: none;
    padding: 0;
    margin: 0;
}

/* Screen reader only class */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

/* Improved form accessibility */
.email-form label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 500;
    color: #1ca78b;
}

.email-form input[type="email"] {
    width: 100%;
    padding: 0.75rem;
    font-size: 1rem;
    border: 2px solid #ddd;
    border-radius: 4px;
    transition: border-color 0.3s ease;
}

.email-form input[type="email"]:focus {
    outline: none;
    border-color: #1ca78a;
    box-shadow: 0 0 0 3px rgba(28, 167, 138, 0.1);
}

.email-form input[type="email"]:invalid {
    border-color: #dc3545;
}

.email-form input[type="email"]:disabled {
    background-color: #e9ecef;
    cursor: not-allowed;
}

.email-form .submit {
    margin-top: 1rem;
    padding: 0.75rem 2rem;
    font-size: 1rem;
    font-weight: 600;
    color: white;
    background-color: #1ca78a;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.1s ease;
}

.email-form .submit:hover:not(:disabled) {
    background-color: #158f74;
    transform: translateY(-1px);
}

.email-form .submit:active:not(:disabled) {
    transform: translateY(0);
}

.email-form .submit:disabled {
    background-color: #6c757d;
    cursor: not-allowed;
    opacity: 0.6;
}

.email-form .submit:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(28, 167, 138, 0.3);
}

/* Compliance text */
.compliance {
    margin-top: 1rem;
    font-size: 0.875rem;
    color: #666;
    line-height: 1.5;
}

.compliance a {
    color: #1ca78a;
    text-decoration: underline;
}

.compliance a:hover {
    color: #158f74;
}

.compliance a:focus {
    outline: 2px solid #1ca78a;
    outline-offset: 2px;
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    .form-message.success {
        border-width: 2px;
    }
    
    .form-message.error {
        border-width: 2px;
    }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
    .form-message,
    .email-form .submit {
        transition: none;
    }
}



















/* footer */

footer{
    display: inline-flex;
    align-items: center;
    justify-content: center ;
    flex-direction: column;
    color: #1ca78b;
    text-decoration: none;
    background-color: #fff;
    width: 100vw;
    padding: 0;
    margin-top: auto;
}


footer a{
    color: #1ca78b !important;
    text-decoration: none;
}


.links a:hover{
    color: #1ca78b !important;  
    text-decoration: underline 1px #1ca78b !important;
}



.footer-con{
  position: fixed;
  bottom: 0;
}


































/* phones */

@media only screen and (max-width: 600px){


body{
    max-width: 100vw !important;
}

.header-si, .header-bg{
    overscroll-behavior-inline: contain;
}

.main-logo{
    margin-left: -5rem;
}

.search-container{
    margin-left: -5rem;
    transform: scale(0.9);
}


.search-container form{
  width: 65vw;
  overscroll-behavior-inline: contain;
}

button.search-icon-btn{
    min-width: 2.5rem !important;
    max-width: 2.5rem !important;
}

.search-icon{
    transform: scale(0.8);
}

input.search-bar{
    max-width: 7.5em;
    border-radius: 0px 23px 23px 0px !important;
}


.right-cont{
    display: none;
}

.icon-container-nav{
    display: flex;
    flex-direction: row;
    margin-top: 1.5em;
    padding: 1%;
}


div.sign-in-phone{
    visibility: visible;
    display: flex;
    flex-direction: row;
    margin-left: 1.25rem !important;
}


div.sign-in-phone p{
    font-weight: bold;
    margin-top: .25rem;
}


circle{
    transform: scaleX(1.01);
}

.notis-num-phone{
    border-radius: 50% !important;
    padding-left: .5rem !important;
    padding-right: .5rem !important;
}

.sign-in-icon-phone{
    transform: scaleY(1.5) !important;
}


.account-icon-phone{
    display: flex !important;
    margin-left: -2.25rem;
    color: #1ca78b;
    transform: scale(1.2);
    margin-top: .25rem;
}

.dropdown-1{
    margin-right: -1rem;
    justify-content: right;
    min-width: 15em;
}

.dropdown-1 li{
    margin-right: 10rem;
    margin-left: 0;
    padding: 0;
    white-space: nowrap;
    justify-content: left;
}

.icons{
    padding-left: .25rem;
    transform: scale(0.7);
    transform: translateY(5px);
}



.phone-notis{
    display: flex;
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
    margin-top: .5rem;
    height: 1.5rem;
}

.notis-num-phone{
    color: #3c3d3c;
    font-weight: 300;
    font-size: smaller;
    background-color: #f2182a;
    border-radius: 27px;
    height: fit-content;
    padding-left: 0.75%;
    padding-right: 0.75%;
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
}



div.options{
    display: grid !important;
    grid-auto-flow: column;
    grid-auto-columns: auto;
    gap: 1rem;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
    margin-left: 1rem;
    padding-bottom: 1rem;
    padding-right: 1rem;
    text-align: left !important;
}

.options-genre{
    visibility: visible;
    display: grid;
}

button.option{
   min-width: fit-content;
   font-size: small; 
   padding: .25rem;
}





















/* posts styling */

.content{
    margin-bottom: 1.5rem;
}

div.img-container{
    display: flex;
    align-items: center;
    justify-content: center;
}

img.thumb{
    text-align: center;
    justify-content: center;
    inline-size: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}


}


p.type{
    margin-top: .35rem;
}















/* tablets */





















/* laptops */

@media only screen and (min-width: 1150px), (max-width: 1500px){
    .options{
        margin-top: 10%;
    }

    div.sign-in{
        margin-left: -10rem;
    }

    .search-icon{
        transform: scale(0.8);
        padding-top: 1px;
    }

    .sign-in-phone{
        display: none;
    }


    input.search-bar{
        border-radius: 0px 23px 23px 0px !important;
    }
    }